SlideShare a Scribd company logo
1 of 9
Download to read offline
注册 | 登录 忘记密码?         51cto首页 | 博客 | 论坛 | 下载   热点文 章 尝试N种低格工具失败,..                              帮助


                                                                                 原创:47    翻译:0    转载:72  
  云计算架构师 -解 占辉  

 http://jeffxie.blog.51cto.com > 复制链接 邀请加入技术圈




                                                                   博客   技术圈    相册      发短 消 息     加 友 情链接

首页 | 情感生活 | 诗词歌赋 | 系统架构 | 程序人生 | 云端计算 | Python | C语言



    解 占辉                       51CTO广东省午饭第二届线下聚会    新浪技术总监杨卫华51CTO开博                             博主的更多文章>>

                                                                 C语言难点分析整理
                                                                                           2010-0 6-11 13:16:45
                                    标签:C语言 难点         [推送到技术圈]


                                  这篇文章主要是介绍一些在复习C语言的过程中笔者个人认为比较重点的地方,较好的掌握这些重点会使对C的
                                  运用更加得心应手。此外会包括一些细节、易错的地方。涉及的主要内容包括:变量的作用域和存储类别、函
                                  数、数组、字符串、指针、文件、链表等。一些最基本的概念在此就不多作解释了,仅希望能有只言片语给同
    博 客统 计信 息                     是C语言初学者的学习和上机过程提供一点点的帮助。
 用户名:解占辉
 文章数:120
 评论数:32                           变量作用域和存储类别:
 访问量:10542
 无忧币:584
                                  了解了基本的变量类型后,我们要进一步了解它的存储类别和变量作用域问题。
 博客积分:920
 博客等级:4
                                  变量类别 子类别
 注册日期:2010-03-18
                                  局部变量 静态变量(离开函数,变量值仍保留)
 距离博客争夺赛结束还有4 天
                                  自动变量
                                  寄存器变量
                                  全局变量 静态变量(只能在本文件中用)
    热 门文 章
                                  非静态变量(允许其他文件使用)
 应邀参加微软虚拟化峰会..
 初试redis,比memcached..
                                  换一个角度
 关于firefox(火狐浏览器)..
 hadoop云框架配置方案
                                  变量类别 子类别
 虚拟化和云计算未来发展趋势
                                  静态存储变量 静态局部变量(函数)
 Hadoop的mapreduce
 云框架Hadoop之部署Hive                 静态全局变量(本文件)

 rsync的安装配置                       非静态全局/外部变量(其他文件引用)
                                  动态存储变量 自动变量
                                  寄存器变量
                                  形式参数
    搜 索 本 博 客内文 章


                                  extern型的存储变量在处理多文件问题时常能用到,在一个文件中定义 extern型的变量即说明这个变量用的

            提 交
                                  是其他文件的。顺便说一下,笔者在做课设时遇到out of memory的错误,于是改成做多文件,再把它includ
                                  e进来(注意自己写的*.h要用“”不用<>),能起到一定的效用。static 型的在读程序写结果的试题中是个
                                  考点。多数时候整个程序会出现多个定义的变量在不同的函数中,考查在不同位置同一变量的值是多少。主要
                                  是遵循一个原则,只要本函数内没有定义的变量就用全局变量(而不是main里的),全局变量和局部变量重名
    我 的 技术圈(2)
                                  时局部变量起作用,当然还要注意静态与自动变量的区别。
 云计算技术交流  
 云端计算新时代  
                                  函数:


                                  对于函数最基本的理解是从那个叫main的单词开始的,一开始总会觉得把语句一并写在main里不是挺好的
    最 近访客                         么,为什么偏择出去。其实这是因为对函数还不够熟练,否则函数的运用会给我们编程带来极大的便利。我们
                                  要知道函数的返回值类型,参数的类型,以及调用函数时的形式。事先的函数说明也能起到一个提醒的好作
用。所谓形参和实参,即在调用函数时写在括号里的就是实参,函数本身用的就是形参,在画流程图时用平行
                           四边形表示传参。
   newzqy        kongy..


                           函数的另一个应用例子就是递归了,笔者开始比较头疼的问题,反应总是比较迟钝,按照老师的方法,把递归
                           的过程耐心准确的逐级画出来,学习的效果还是比较好的,会觉得这种递归的运用是挺巧的,事实上,著名的
   76418..       lovej..   八皇后、汉诺塔等问题都用到了递归。


                           例子:
                            
    bitte..      seabe..




  tomax_li       xiaoyu




    oklil..      tonyx..




    最 新评 论                 数组:
tonyxiaohome:写太好了,我推
荐到我的圈子里面了..                分为一维数组和多维数组,其存储方式画为表格的话就会一目了然,其实就是把相同类型的变量有序的放在一
                           起。因此,在处理比较多的数据时(这也是大多数的情况)数组的应用范围是非常广的。
tonyxiaohome:写太好了,我已
经推荐到我的圈子里..
                           具体的实际应用不便举例,而且绝大多数是与指针相结合的,笔者个人认为学习数组在更大程度上是为学习指
tonyxiaohome:写太好了,我已       针做一个铺垫。作为基础的基础要明白几种基本操作:即数组赋值、打印、排序(冒泡排序法和选择排序
经推荐到我的圈子里..                法)、查找。这些都不可避免的用到循环,如果觉得反应不过来,可以先一点点的把循环展开,就会越来越熟
                           悉,以后自己编写一个功能的时候就会先找出内在规律,较好的运用了。另外数组做参数时,一维的[]里可以
解 占辉:恩,这个第一次参加这么大
                           是空的,二维的第一个[]里可以是空的但是第二个[]中必须规定大小。
的会议,也..
                           冒泡法排序函数:
roy91074:电脑清洁工具是思杰             void bubble( int a[] , int n) 
公司的。。。是..                      { 
                                   int i,j,k; 
                                   for (i=1,i<n;i++) 
                                   for (j=0;j< n-i-1; j++) 

    51CTO推 荐 博 文                   if (a[j]>a[j+1]) 
                                   { 
Asp.net MVC2 初探
                                       k=a[j]; 
Qt学习之路:创建share..
                                       a[j]=a[j+1]; 
把Swing的Icon转换到SW..
                                       a[j+1]=k; 
像说话一样写代码
                                   } 
Java处理带BOM的文本
                               } 
亲手制作山寨版Log4J
解读AzureAppFabric架..        选择法排序函数:

给软件工程师的12条单..                   void sort( int a[] , int n) 
Silverlight & Blend动..          { 
多主对一从的Mysql复制..                     int i,j,k,t; 
WCF4.0新特性预览及学..                     for (i=0,i< n-1 ;i++) 
                                    { 
                                        k=i ; 
                                        for ( j=i+1 ;j<n;j++) 
    友 情链接
                                            if (a[k]<a[j]) k=j ; 
  邵程程d e蜗居
                                        if ( k!=i ) 
  运维工作记录
                                        { 
  老老仙(新浪的家)
                                            t=a[i]; 
  老老仙(百度的家)
                                            a[i]=a[k]; 
  python中国
                                            a[k]=t; 
  sery                                  } 
  51CTO博客开发
                                    } 
                                } 




                           折半查找函数(原数组有序):
void search( int a[] , int n, int x) 
  { 
      int left=0,right=n-1,mid,flag=0; 
      while ((flag==0)&&(left<=right)) 
      { 
          mid=(left+right)/2 ; 
          if (x==a[mid]) 
          { 
              printf(" %d%d ",x,mid); 
              flag =1; 
          } 
          else if (x<a[mid]) right=mid-1; 
          else left=mid+1 ; 
      } 
  } 




相关常用的算法还有 判断回文,求阶乘,Fibanacci数列,任意进制转换,杨辉三角形计算 等等 。


字符串:


字符串其实就是一个数组(指针),在scanf的输入列中是不需要在前面加“&”符号的,因为字符数组名本身
即代表地址。值得注意的是字符串末尾的 ‘0',如果没有的话,字符串很有可能会不正常的打印。另外就是
字符串的定义和赋值问题了,笔者有一次的比较综合的上机作业就是字符串打印老是乱码,上上下下找了一圈
问题,最后发现是因为


char *name;


而不是


char name[10];


前者没有说明指向哪儿,更没有确定大小,导致了乱码的错误,印象挺深刻的。


另外,字符串的赋值也是需要注意的,如果是用字符指针的话,既可以定义的时候赋初值,即


char *a="Abcdefg";


也可以在赋值语句中赋值,即


char *a;
a=" Abcdefg ";


但如果是用字符数组的话,就只能在定义时整体赋初值,即char a[5]={"abcd"};而不能在赋值语句中整体赋
值。


常用字符串函数列表如下,要会自己实现:


函数作用 函数调用形式 备注
字符串拷贝函数 strcpy(char*,char *) 后者拷贝到前者
字符串追加函数 strcat(char*,char *) 后者追加到前者后,返回前者,因此前者空间要足够大
字符串比较函数 strcmp(char*,char *) 前者等于、小于、大于后者时,返回0、正值、负值。注意,不是
比较长度,是比较字符ASCII码的大小,可用于按姓名字母排序等。
字符串长度 strlen(char *) 返回字符串的长度,不包括'0'.转义字符算一个字符。
字符串型->整型 atoi(char *)
整型->字符串型 itoa(int,char *,int) 做课设时挺有用的
sprintf(char *,格式化输入) 赋给字符串,而不打印出来。课设时用也比较方便


注: 对字符串是不允许做==或!=的运算的,只能用字符串比较函数


指针:
指针可以说是C语言中最关键的地方了,其实这个“指针”的名字对于这个概念的理解是十分形象的。首先要
知道,指针变量的值(即指针变量中存放的值)是指针(即地址)。指针变量定义形式中:基本类型 *指针变
量名 中的“*”代表的是这是一个指向该基本类型的指针变量,而不是内容的意思。在以后使用的时候,如*pt
r=a时,“*”才表示ptr所指向的地址里放的内容是a。


指针比较典型又简单的一应用例子是两数互换,看下面的程序,

    swap( int c, int d ) 
    { 
        int t; 
        t=c; 
        c=d; 
        d=t; 
    } 
    main() 
    { 
        int a=2,b=3; 
        swap( a,b ); 
        printf(“%d,%d”,a,b); 
    }  




这是不能实现a和b的数值互换的,实际上只是形参在这个函数中换来换去,对实参没什么影响。现在,用指针
类型的数据做为参数的话,更改如下:

    swap(#3333FF *p1, int *p2) 
    { 
        int t; 
        t=*p1; 
        *p1=*p2; 
        *p2=t; 
    } 
    main() 
    { 
        int a=2,b=3; 
        int *ptr1,*ptr2; 
        ptr1=&a; 
        ptr2=&b; 
        swap(prt1,ptr2); 
        printf(“%d,%d”,a,b); 
    }  




这样在swap中就把p1,p2 的内容给换了,即把a,b的值互换了。


指针可以执行 增、减运算 ,结合++运算符的法则,我们可以看到:


*++s 取指针变量加1以后的内容


*s++ 取指针变量所指内容后s再加1
(*s)++ 指针变量指的内容加1


指针和数组 实际上几乎是一样的,数组名可以看成是一个常量指针,一维数组中ptr=&b[0]则下面的表示法
是等价的:


a[3]等价于* (a+3)
ptr[3]等价于*(ptr+3)


下面看一个用指针来自己实现atoi(字符串型->整型)函数:
 




指向多维数组的指针变量也是一个比较广泛的运用。例如数组a[3][4],a代表的实际是整个二维数组的首地
址,即第0行的首地址,也就是一个指针变量。而a+1就不是简单的在数值上加上1了,它代表的不是a[0]
[1],而是第1行的首地址,&a[1][0]。
指针变量常用的用途还有把指针作为参数传递给其他函数,即 指向函数的指针 。
看下面的几行代码:
void Input(ST *); void Output(ST *); void Bubble(ST *); void Find(ST *); void Failure(ST
*); /*函数声明:这五个函数都是以一个指向ST型(事先定义过)结构的指针变量作为参数,无返回值。*/ void
(*process[5])(ST *) ={Input,Output,Bubble,Find,Failure}; /*process被调用时提供5种功能不同的

函数共选择(指向函数的指针数组)*/ printf( "nChoose:n?" ); scanf( "%d" ,&choice); if (choice
>=0&&choice<=4) (*process[ choice ])(a); /*调用相应的函数实现不同功能*;/




总之,指针的应用是非常灵活和广泛的,不是三言两语能说完的,上面几个小例子只是个引子,实际编程中,
会逐渐发现运用指针所能带来的便利和高效率。


文件:


函数调用形式 说明
fopen("路径","打开方式") 打开文件
fclose(FILE *) 防止之后被误用
fgetc(FILE *) 从文件中读取一个字符
fputc(ch,FILE *) 把ch代表的字符写入这个文件里
fgets(FILE *) 从文件中读取一行
fputs(FILE *) 把一行写入文件中
fprintf(FILE *,"格式字符串",输出表列) 把数据写入文件
fscanf(FILE *,"格式字符串",输入表列) 从文件中读取
fwrite(地址,sizeof(),n,FILE *) 把地址中n个sizeof大的数据写入文件里
fread(地址,sizeof(),n,FILE *) 把文件中n个sizeof大的数据读到地址里
rewind(FILE *) 把文件指针拨回到文件头
fseek(FILE *,x,0/1/2) 移动文件指针。第二个参数是位移量,0代表从头移,1代表从当前位置移,2
代表从文件尾移。
feof(FILE *) 判断是否到了文件末尾


文件打开方式 说明
r 打开只能读的文件
w 建立供写入的文件,如果已存在就抹去原有数据
a 打开或建立一个把数据追加到文件尾的文件
r+ 打开用于更新数据的文件
w+ 建立用于更新数据的文件,如果已存在就抹去原有数据
a+ 打开或建立用于更新数据的文件,数据追加到文件尾


注: 以上用于文本文件的操作,如果是二进制文件就在上述字母后加“b”。


我们用文件最大的目的就是能让数据保存下来。因此在要用文件中数据的时候,就是要把数据读到一个结构
(一般保存数据多用结构,便于管理)中去,再对结构进行操作即可。例如,文件aa.data中存储的是30个学
生的成绩等信息,要遍历这些信息,对其进行成绩输出、排序、查找等工作时,我们就把这些信息先读入到一
个结构数组中,再对这个数组进行操作。如下例:

  #include <stdio.h> 
  #include <stdlib.h> 
  #define N 30 
  typedef struct student /*定义储存学生成绩信息的数组*/ 
  { 
      char *name; 
      int chinese; 
      int maths; 
      int phy; 
      int total; 
  } ST ; 


  main() 
  { 
      ST a[N] ; /*存储N个学生信息的数组*/ 
      FILE *fp ; 
      void (*process[3])(ST *) ={Output,Bubble,Find}; /*实现相关功能的三个函数*/ 
      int choice,i=0; 
    Show(); 
    printf( " Choose: ?" ); 
    scanf( "%d" ,&choice); 
    while (choice>=0&&choice<=2) 
    { 
        fp=fopen( "aa.dat" , "rb" ) ; 
        for (i=0; i<N ;i++) 
            fread(&a[i], sizeof (ST),1,fp); /*把文件中储存的信息逐个读到数组中去*/ 
        fclose(fp); 
        (*process[choice]) (a ); /*前面提到的指向函数的指针,选择操作*/ 
        printf( " " ); 
        Show(); 
        printf( " ?" ); 
        scanf( "%d" ,&choice); 
    } 
} 


void Show() 
{ 
    printf( " ****Choices:**** 0.Display the data form 1.Bubble it according to th
e total score 2.Search 3.Quit! " ); 
} 


void Output( ST *a ) /*将文件中存储的信息逐个输出*/ 
{ 
    int i,t=0; 
    printf( "Name Chinese Maths Physics Total " ); 
    for (i=0;i<N;i++) 
    { 
        t=a[i].chinese+a[i].maths+a[i].phy; 
        a[i].total=t; 
        printf( "%4s%8d%8d%8d%8d " ,a[i].name,a[i].chinese,a[i].maths,a[i].phy,a[i].
total); 
    } 
} 


void Bubble( ST *a) /*对数组进行排序,并输出结果*/ 
{ 
    int i,pass; 
    ST m; 
    for (pass=0;pass <N-1 ;pass++) 
        for (i=0;i <N-1 ;i++) 
            if (a[i].total<a[i+1].total) 
            { 
                m=a[i]; /*结构互换*/ 
                a[i]=a[i+1]; 
                a[i+1]=m; 
            } 
    Output( a ); 
} 


void Find (ST *a) 
{ 
    int i,t=1; 
    char m[20]; 
    printf( " Enter the name you want:" ); 
    scanf( "%s" ,m); 
    for (i=0;i<N;i++) 
    if ( !strcmp(m,a[i].name)) /*根据姓名匹配情况输出查找结果*/ 
    { 
        printf( " The result is: %s, Chinese:%d, Maths:%d, Physics:%d,Total:%d " ,m,
a[i].chinese,a[i].maths,a[i].phy,a[i].total); 
        t=0 ; 
    } 
    if ( t ) 
        printf( " The name is not in the list! " ); 
} 




链表:
链表是C语言中另外一个难点。牵扯到结点、动态分配空间等等。用结构作为链表的结点是非常适合的,例
如:
     struct node 
     { 
         int data; 
         struct node *next; 
     };  




其中next是指向自身所在结构类型的指针,这样就可以把一个个结点相连,构成链表。


链表结构的一大优势就是动态分配存储,不会像数组一样必须在定义时确定大小,造成不必要的浪费。用mall
o c和free函数即可实现开辟和释放存储单元。其中,malloc的参数多用 sizeof运算符计算得到。


链表的基本操作有: 正、反向建立链表;输出链表;删除链表中结点;在链表中插入结点 等等,都是要熟练
掌握的,初学者通过 画图 的方式能比较形象地理解建立、插入等实现的过程。

    typedef struct node 
    { 
        char data; 
        struct node *next; 
    } NODE ; /*结点*/ 




正向建立链表:
 




逆向建立:
     NODE *create() 
     { 
         char ch= 'a' ; 
         NODE *p,*h=NULL; 
         while (ch<= 'z' ) 
        { 
             p= (NODE *)malloc( sizeof (NODE)) ; 
             p->data=ch; 
             p->next=h; /*不断地把head往前挪*/ 
             h=p; 
             ch++; 
         } 
         return h; 
     }  
用递归实现链表逆序输出:

 void output(NODE *h) 
 { 
    if (h!=NULL) 
    { 
       output(h->next) ; 
       printf( "%c" ,h->data); 
    } 
 }  




插入结点(已有升序的链表):

 NODE *insert(NODE *h, int x) 
 { 
     NODE * new ,*front,*current=h; 
     while (current!=NULL&&(current->data<x)) /*查找插入的位置*/ 
     { 
         front=current; 
         current=current->next; 
     } 
     new = (NODE *)malloc( sizeof (NODE)) ; 
     new ->data=x; 
     new ->next=current; 
     if (current==h) /*判断是否是要插在表头*/ 
         h= new ; 
     else front->next= new ; 
     return h; 
 }  




删除结点:

 NODE * delete (NODE *h, int x) 
 { 
     NODE *q,*p=h; 
     while (p!=NULL&&(p->data!=x)) 
     { 
         q=p; 
         p=p->next; 
     } 
     if (p->data==x) /*找到了要删的结点*/ 
     { 
         if (p==h) /*判断是否要删表头*/ 
             h=h->next; 
         else q->next=p->next; 
         free(p); /*释放掉已删掉的结点*/ 
     } 
     return h; 
 }
上一篇 Map Reduce – the Free Lunch is not over?    下一篇 程序崩了,咋办?

                                            类别:C语言         技术圈(2)   阅读(95)   评论(1)   推送到技术圈      返回首页  




        相关文 章

       谭浩强C语言程序设计                                    网络语言对作文教学的冲击
       程序员和C语言没有必然联系                                 C语言专题——标准库<math.h>
       C语言实现每一分钟打开一次文件夹                              将对setjmp与longjmp的具体使用方法和适用的..
       C语言编程宝典之一 读书笔记                                谁能帮我解决这个问题??
       C语言的起源                                        C语言嵌入式系统编程修炼(软件架构篇)




        文 章评 论
 

    [1楼]       tonyxiaohome
                                                                                     2010-06-12 13:04:06
    写太好了,我推荐到我的圈子里面了,http://g.51cto.com/tonyxiaohome,
    有空来坐坐,大家交个朋友。


 




     发表评 论

       昵   称:                                                              登录  快速注册
       验证码:
                                        请点击后输入验证码 博客过2级,无需填写验证码
       内   容:                                                         5




                                                                      6
                                                     提 交




                       Copyright By 51CTO.COM 版权所有




                                                                               converted by Web2PDFConvert.com

More Related Content

What's hot

認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算建興 王
 
深入理解Andorid重难点
深入理解Andorid重难点深入理解Andorid重难点
深入理解Andorid重难点Bin Shao
 
Scala function-and-closures
Scala function-and-closuresScala function-and-closures
Scala function-and-closureswang hongjiang
 
Ecmascript
EcmascriptEcmascript
Ecmascriptjay li
 
潜力无限的编程语言Javascript
潜力无限的编程语言Javascript潜力无限的编程语言Javascript
潜力无限的编程语言Javascriptjay li
 
Google protocol buffers简析
Google protocol buffers简析Google protocol buffers简析
Google protocol buffers简析wavefly
 
Programming python - part 1
Programming python - part 1Programming python - part 1
Programming python - part 1Che-Cheng Hsu
 
C++11 smart pointers
C++11 smart pointersC++11 smart pointers
C++11 smart pointerschchwy Chang
 
2, object oriented programming
2, object oriented programming2, object oriented programming
2, object oriented programmingted-xu
 
Slide08 807007748
Slide08 807007748Slide08 807007748
Slide08 807007748Shiyao Ma
 
Java相关基础知识
Java相关基础知识Java相关基础知识
Java相关基础知识yiditushe
 
長庚 0511.2011(曾懷恩教授演講)
長庚 0511.2011(曾懷恩教授演講)長庚 0511.2011(曾懷恩教授演講)
長庚 0511.2011(曾懷恩教授演講)noritsai
 
Java 開發者的函數式程式設計
Java 開發者的函數式程式設計Java 開發者的函數式程式設計
Java 開發者的函數式程式設計Justin Lin
 

What's hot (18)

認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算認識 C++11 新標準及使用 AMP 函式庫作平行運算
認識 C++11 新標準及使用 AMP 函式庫作平行運算
 
深入理解Andorid重难点
深入理解Andorid重难点深入理解Andorid重难点
深入理解Andorid重难点
 
Scala function-and-closures
Scala function-and-closuresScala function-and-closures
Scala function-and-closures
 
functional-scala
functional-scalafunctional-scala
functional-scala
 
Ecmascript
EcmascriptEcmascript
Ecmascript
 
潜力无限的编程语言Javascript
潜力无限的编程语言Javascript潜力无限的编程语言Javascript
潜力无限的编程语言Javascript
 
Java 網路程式
Java 網路程式Java 網路程式
Java 網路程式
 
Google protocol buffers简析
Google protocol buffers简析Google protocol buffers简析
Google protocol buffers简析
 
Programming python - part 1
Programming python - part 1Programming python - part 1
Programming python - part 1
 
Hi Haskell
Hi HaskellHi Haskell
Hi Haskell
 
Dev307
Dev307Dev307
Dev307
 
C++11 smart pointers
C++11 smart pointersC++11 smart pointers
C++11 smart pointers
 
2, object oriented programming
2, object oriented programming2, object oriented programming
2, object oriented programming
 
[系列活動] Python爬蟲實戰
[系列活動] Python爬蟲實戰[系列活動] Python爬蟲實戰
[系列活動] Python爬蟲實戰
 
Slide08 807007748
Slide08 807007748Slide08 807007748
Slide08 807007748
 
Java相关基础知识
Java相关基础知识Java相关基础知识
Java相关基础知识
 
長庚 0511.2011(曾懷恩教授演講)
長庚 0511.2011(曾懷恩教授演講)長庚 0511.2011(曾懷恩教授演講)
長庚 0511.2011(曾懷恩教授演講)
 
Java 開發者的函數式程式設計
Java 開發者的函數式程式設計Java 開發者的函數式程式設計
Java 開發者的函數式程式設計
 

Similar to getPDF.aspx

看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)
看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)
看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)永立 連
 
Recycle Open Source Projects
Recycle Open Source ProjectsRecycle Open Source Projects
Recycle Open Source ProjectsGeorge Ang
 
2006 recycle opensourceprojects
2006 recycle opensourceprojects2006 recycle opensourceprojects
2006 recycle opensourceprojectsGeorge Ang
 
软件工程
软件工程软件工程
软件工程bill0077
 
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VM
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VMCompiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VM
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VMLi Hsuan Hung
 
數位出版2.0 it
數位出版2.0 it數位出版2.0 it
數位出版2.0 it志賢 黃
 
ES5 introduction
ES5 introductionES5 introduction
ES5 introductionotakustay
 
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509tidesq
 
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社pingjiang
 
信息系统开发平台OpenExpressApp
信息系统开发平台OpenExpressApp信息系统开发平台OpenExpressApp
信息系统开发平台OpenExpressAppzhoujg
 
C++工程实践
C++工程实践C++工程实践
C++工程实践Shuo Chen
 
Lotus domino开发教程
Lotus domino开发教程Lotus domino开发教程
Lotus domino开发教程dyzm_2000
 
模块一-Go语言特性.pdf
模块一-Go语言特性.pdf模块一-Go语言特性.pdf
模块一-Go语言特性.pdfczzz1
 
C++模板与泛型编程
C++模板与泛型编程C++模板与泛型编程
C++模板与泛型编程deer hope
 
实习生答辩Finally
实习生答辩Finally实习生答辩Finally
实习生答辩FinallyMars007
 
千呼萬喚始出來的Java SE 7
千呼萬喚始出來的Java SE 7千呼萬喚始出來的Java SE 7
千呼萬喚始出來的Java SE 7javatwo2011
 
Web爬虫那点事
Web爬虫那点事Web爬虫那点事
Web爬虫那点事Yihua Huang
 
数据处理算法设计要点
数据处理算法设计要点数据处理算法设计要点
数据处理算法设计要点thinkinlamp
 

Similar to getPDF.aspx (20)

看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)
看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)
看似比較簡單的推坑教學 C語言從崩潰到崩潰Ex(二)
 
Recycle Open Source Projects
Recycle Open Source ProjectsRecycle Open Source Projects
Recycle Open Source Projects
 
2006 recycle opensourceprojects
2006 recycle opensourceprojects2006 recycle opensourceprojects
2006 recycle opensourceprojects
 
软件工程
软件工程软件工程
软件工程
 
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VM
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VMCompiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VM
Compiler for Dummy 一點都不深入的了解 Compiler, Interpreter 和 VM
 
數位出版2.0 it
數位出版2.0 it數位出版2.0 it
數位出版2.0 it
 
ES5 introduction
ES5 introductionES5 introduction
ES5 introduction
 
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509
Linux c++ 编程之链接与装载 -基础篇--v0.3--20120509
 
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社
数据结构(用面向对象方法与C++语言描述第二版)殷人昆编著清华大学出版社
 
信息系统开发平台OpenExpressApp
信息系统开发平台OpenExpressApp信息系统开发平台OpenExpressApp
信息系统开发平台OpenExpressApp
 
C++工程实践
C++工程实践C++工程实践
C++工程实践
 
Lotus domino开发教程
Lotus domino开发教程Lotus domino开发教程
Lotus domino开发教程
 
模块一-Go语言特性.pdf
模块一-Go语言特性.pdf模块一-Go语言特性.pdf
模块一-Go语言特性.pdf
 
C++模板与泛型编程
C++模板与泛型编程C++模板与泛型编程
C++模板与泛型编程
 
实习生答辩Finally
实习生答辩Finally实习生答辩Finally
实习生答辩Finally
 
[系列活動] Python 爬蟲實戰
[系列活動] Python 爬蟲實戰[系列活動] Python 爬蟲實戰
[系列活動] Python 爬蟲實戰
 
Python系列4
Python系列4Python系列4
Python系列4
 
千呼萬喚始出來的Java SE 7
千呼萬喚始出來的Java SE 7千呼萬喚始出來的Java SE 7
千呼萬喚始出來的Java SE 7
 
Web爬虫那点事
Web爬虫那点事Web爬虫那点事
Web爬虫那点事
 
数据处理算法设计要点
数据处理算法设计要点数据处理算法设计要点
数据处理算法设计要点
 

More from byron zhao

从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】byron zhao
 
从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】byron zhao
 
网页设计语言教程Html css
网页设计语言教程Html css网页设计语言教程Html css
网页设计语言教程Html cssbyron zhao
 
Digital booklet sparks fly deluxe
Digital booklet   sparks fly deluxeDigital booklet   sparks fly deluxe
Digital booklet sparks fly deluxebyron zhao
 
《电子技术基础(模拟部分)》康华光第五版...(1)
《电子技术基础(模拟部分)》康华光第五版...(1)《电子技术基础(模拟部分)》康华光第五版...(1)
《电子技术基础(模拟部分)》康华光第五版...(1)byron zhao
 
回转器的原理与应用
回转器的原理与应用回转器的原理与应用
回转器的原理与应用byron zhao
 
新概念第四册课文打印版
新概念第四册课文打印版新概念第四册课文打印版
新概念第四册课文打印版byron zhao
 
实验报告4:使用SQL语句进行SQL Server 2000数据库操作
实验报告4:使用SQL语句进行SQL Server 2000数据库操作实验报告4:使用SQL语句进行SQL Server 2000数据库操作
实验报告4:使用SQL语句进行SQL Server 2000数据库操作byron zhao
 
未命名 1.odt
未命名 1.odt未命名 1.odt
未命名 1.odtbyron zhao
 
小波变换程序
小波变换程序小波变换程序
小波变换程序byron zhao
 
小波变换程序.odt
小波变换程序.odt小波变换程序.odt
小波变换程序.odtbyron zhao
 
健康上网专家密码
健康上网专家密码健康上网专家密码
健康上网专家密码byron zhao
 
大物实验报告(太阳能电池).odt
大物实验报告(太阳能电池).odt大物实验报告(太阳能电池).odt
大物实验报告(太阳能电池).odtbyron zhao
 
2009级 截止至2011年1月成绩汇总表
2009级 截止至2011年1月成绩汇总表2009级 截止至2011年1月成绩汇总表
2009级 截止至2011年1月成绩汇总表byron zhao
 

More from byron zhao (20)

从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】
 
从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】从研究生角度,回望大学四年数学建模路【原创】
从研究生角度,回望大学四年数学建模路【原创】
 
网页设计语言教程Html css
网页设计语言教程Html css网页设计语言教程Html css
网页设计语言教程Html css
 
Digital booklet sparks fly deluxe
Digital booklet   sparks fly deluxeDigital booklet   sparks fly deluxe
Digital booklet sparks fly deluxe
 
《电子技术基础(模拟部分)》康华光第五版...(1)
《电子技术基础(模拟部分)》康华光第五版...(1)《电子技术基础(模拟部分)》康华光第五版...(1)
《电子技术基础(模拟部分)》康华光第五版...(1)
 
电路作业
电路作业电路作业
电路作业
 
Multisim8
Multisim8Multisim8
Multisim8
 
回转器的原理与应用
回转器的原理与应用回转器的原理与应用
回转器的原理与应用
 
新概念第四册课文打印版
新概念第四册课文打印版新概念第四册课文打印版
新概念第四册课文打印版
 
实验报告4:使用SQL语句进行SQL Server 2000数据库操作
实验报告4:使用SQL语句进行SQL Server 2000数据库操作实验报告4:使用SQL语句进行SQL Server 2000数据库操作
实验报告4:使用SQL语句进行SQL Server 2000数据库操作
 
未命名 1.odt
未命名 1.odt未命名 1.odt
未命名 1.odt
 
027501-01
027501-01027501-01
027501-01
 
小波变换程序
小波变换程序小波变换程序
小波变换程序
 
未命名 24
未命名 24未命名 24
未命名 24
 
小波变换程序.odt
小波变换程序.odt小波变换程序.odt
小波变换程序.odt
 
刚体
刚体刚体
刚体
 
健康上网专家密码
健康上网专家密码健康上网专家密码
健康上网专家密码
 
大物实验报告(太阳能电池).odt
大物实验报告(太阳能电池).odt大物实验报告(太阳能电池).odt
大物实验报告(太阳能电池).odt
 
2009级 截止至2011年1月成绩汇总表
2009级 截止至2011年1月成绩汇总表2009级 截止至2011年1月成绩汇总表
2009级 截止至2011年1月成绩汇总表
 
电路作业
电路作业电路作业
电路作业
 

getPDF.aspx

  • 1. 注册 | 登录 忘记密码? 51cto首页 | 博客 | 论坛 | 下载 热点文 章 尝试N种低格工具失败,.. 帮助 原创:47 翻译:0 转载:72    云计算架构师 -解 占辉   http://jeffxie.blog.51cto.com > 复制链接 邀请加入技术圈 博客 技术圈 相册 发短 消 息 加 友 情链接 首页 | 情感生活 | 诗词歌赋 | 系统架构 | 程序人生 | 云端计算 | Python | C语言 解 占辉 51CTO广东省午饭第二届线下聚会    新浪技术总监杨卫华51CTO开博 博主的更多文章>> C语言难点分析整理 2010-0 6-11 13:16:45 标签:C语言 难点 [推送到技术圈] 这篇文章主要是介绍一些在复习C语言的过程中笔者个人认为比较重点的地方,较好的掌握这些重点会使对C的 运用更加得心应手。此外会包括一些细节、易错的地方。涉及的主要内容包括:变量的作用域和存储类别、函 数、数组、字符串、指针、文件、链表等。一些最基本的概念在此就不多作解释了,仅希望能有只言片语给同 博 客统 计信 息 是C语言初学者的学习和上机过程提供一点点的帮助。 用户名:解占辉 文章数:120 评论数:32 变量作用域和存储类别: 访问量:10542 无忧币:584 了解了基本的变量类型后,我们要进一步了解它的存储类别和变量作用域问题。 博客积分:920 博客等级:4 变量类别 子类别 注册日期:2010-03-18 局部变量 静态变量(离开函数,变量值仍保留) 距离博客争夺赛结束还有4 天 自动变量 寄存器变量 全局变量 静态变量(只能在本文件中用) 热 门文 章 非静态变量(允许其他文件使用) 应邀参加微软虚拟化峰会.. 初试redis,比memcached.. 换一个角度 关于firefox(火狐浏览器).. hadoop云框架配置方案 变量类别 子类别 虚拟化和云计算未来发展趋势 静态存储变量 静态局部变量(函数) Hadoop的mapreduce 云框架Hadoop之部署Hive 静态全局变量(本文件) rsync的安装配置 非静态全局/外部变量(其他文件引用) 动态存储变量 自动变量 寄存器变量 形式参数 搜 索 本 博 客内文 章 extern型的存储变量在处理多文件问题时常能用到,在一个文件中定义 extern型的变量即说明这个变量用的 提 交 是其他文件的。顺便说一下,笔者在做课设时遇到out of memory的错误,于是改成做多文件,再把它includ e进来(注意自己写的*.h要用“”不用<>),能起到一定的效用。static 型的在读程序写结果的试题中是个 考点。多数时候整个程序会出现多个定义的变量在不同的函数中,考查在不同位置同一变量的值是多少。主要 是遵循一个原则,只要本函数内没有定义的变量就用全局变量(而不是main里的),全局变量和局部变量重名 我 的 技术圈(2) 时局部变量起作用,当然还要注意静态与自动变量的区别。 云计算技术交流   云端计算新时代   函数: 对于函数最基本的理解是从那个叫main的单词开始的,一开始总会觉得把语句一并写在main里不是挺好的 最 近访客 么,为什么偏择出去。其实这是因为对函数还不够熟练,否则函数的运用会给我们编程带来极大的便利。我们 要知道函数的返回值类型,参数的类型,以及调用函数时的形式。事先的函数说明也能起到一个提醒的好作
  • 2. 用。所谓形参和实参,即在调用函数时写在括号里的就是实参,函数本身用的就是形参,在画流程图时用平行 四边形表示传参。 newzqy kongy.. 函数的另一个应用例子就是递归了,笔者开始比较头疼的问题,反应总是比较迟钝,按照老师的方法,把递归 的过程耐心准确的逐级画出来,学习的效果还是比较好的,会觉得这种递归的运用是挺巧的,事实上,著名的 76418.. lovej.. 八皇后、汉诺塔等问题都用到了递归。 例子:   bitte.. seabe.. tomax_li xiaoyu oklil.. tonyx.. 最 新评 论 数组: tonyxiaohome:写太好了,我推 荐到我的圈子里面了.. 分为一维数组和多维数组,其存储方式画为表格的话就会一目了然,其实就是把相同类型的变量有序的放在一 起。因此,在处理比较多的数据时(这也是大多数的情况)数组的应用范围是非常广的。 tonyxiaohome:写太好了,我已 经推荐到我的圈子里.. 具体的实际应用不便举例,而且绝大多数是与指针相结合的,笔者个人认为学习数组在更大程度上是为学习指 tonyxiaohome:写太好了,我已 针做一个铺垫。作为基础的基础要明白几种基本操作:即数组赋值、打印、排序(冒泡排序法和选择排序 经推荐到我的圈子里.. 法)、查找。这些都不可避免的用到循环,如果觉得反应不过来,可以先一点点的把循环展开,就会越来越熟 悉,以后自己编写一个功能的时候就会先找出内在规律,较好的运用了。另外数组做参数时,一维的[]里可以 解 占辉:恩,这个第一次参加这么大 是空的,二维的第一个[]里可以是空的但是第二个[]中必须规定大小。 的会议,也.. 冒泡法排序函数: roy91074:电脑清洁工具是思杰 void bubble( int a[] , int n)  公司的。。。是.. {      int i,j,k;      for (i=1,i<n;i++)      for (j=0;j< n-i-1; j++)  51CTO推 荐 博 文     if (a[j]>a[j+1])      {  Asp.net MVC2 初探         k=a[j];  Qt学习之路:创建share..         a[j]=a[j+1];  把Swing的Icon转换到SW..         a[j+1]=k;  像说话一样写代码     }  Java处理带BOM的文本 }  亲手制作山寨版Log4J 解读AzureAppFabric架.. 选择法排序函数: 给软件工程师的12条单.. void sort( int a[] , int n)  Silverlight & Blend动.. {  多主对一从的Mysql复制..     int i,j,k,t;  WCF4.0新特性预览及学..     for (i=0,i< n-1 ;i++)      {          k=i ;          for ( j=i+1 ;j<n;j++)  友 情链接             if (a[k]<a[j]) k=j ;    邵程程d e蜗居         if ( k!=i )    运维工作记录         {    老老仙(新浪的家)             t=a[i];    老老仙(百度的家)             a[i]=a[k];    python中国             a[k]=t;    sery         }    51CTO博客开发     }  }  折半查找函数(原数组有序):
  • 3. void search( int a[] , int n, int x)  {      int left=0,right=n-1,mid,flag=0;      while ((flag==0)&&(left<=right))      {          mid=(left+right)/2 ;          if (x==a[mid])          {              printf(" %d%d ",x,mid);              flag =1;          }          else if (x<a[mid]) right=mid-1;          else left=mid+1 ;      }  }  相关常用的算法还有 判断回文,求阶乘,Fibanacci数列,任意进制转换,杨辉三角形计算 等等 。 字符串: 字符串其实就是一个数组(指针),在scanf的输入列中是不需要在前面加“&”符号的,因为字符数组名本身 即代表地址。值得注意的是字符串末尾的 ‘0',如果没有的话,字符串很有可能会不正常的打印。另外就是 字符串的定义和赋值问题了,笔者有一次的比较综合的上机作业就是字符串打印老是乱码,上上下下找了一圈 问题,最后发现是因为 char *name; 而不是 char name[10]; 前者没有说明指向哪儿,更没有确定大小,导致了乱码的错误,印象挺深刻的。 另外,字符串的赋值也是需要注意的,如果是用字符指针的话,既可以定义的时候赋初值,即 char *a="Abcdefg"; 也可以在赋值语句中赋值,即 char *a; a=" Abcdefg "; 但如果是用字符数组的话,就只能在定义时整体赋初值,即char a[5]={"abcd"};而不能在赋值语句中整体赋 值。 常用字符串函数列表如下,要会自己实现: 函数作用 函数调用形式 备注 字符串拷贝函数 strcpy(char*,char *) 后者拷贝到前者 字符串追加函数 strcat(char*,char *) 后者追加到前者后,返回前者,因此前者空间要足够大 字符串比较函数 strcmp(char*,char *) 前者等于、小于、大于后者时,返回0、正值、负值。注意,不是 比较长度,是比较字符ASCII码的大小,可用于按姓名字母排序等。 字符串长度 strlen(char *) 返回字符串的长度,不包括'0'.转义字符算一个字符。 字符串型->整型 atoi(char *) 整型->字符串型 itoa(int,char *,int) 做课设时挺有用的 sprintf(char *,格式化输入) 赋给字符串,而不打印出来。课设时用也比较方便 注: 对字符串是不允许做==或!=的运算的,只能用字符串比较函数 指针:
  • 4. 指针可以说是C语言中最关键的地方了,其实这个“指针”的名字对于这个概念的理解是十分形象的。首先要 知道,指针变量的值(即指针变量中存放的值)是指针(即地址)。指针变量定义形式中:基本类型 *指针变 量名 中的“*”代表的是这是一个指向该基本类型的指针变量,而不是内容的意思。在以后使用的时候,如*pt r=a时,“*”才表示ptr所指向的地址里放的内容是a。 指针比较典型又简单的一应用例子是两数互换,看下面的程序, swap( int c, int d )  {      int t;      t=c;      c=d;      d=t;  }  main()  {      int a=2,b=3;      swap( a,b );      printf(“%d,%d”,a,b);  }   这是不能实现a和b的数值互换的,实际上只是形参在这个函数中换来换去,对实参没什么影响。现在,用指针 类型的数据做为参数的话,更改如下: swap(#3333FF *p1, int *p2)  {      int t;      t=*p1;      *p1=*p2;      *p2=t;  }  main()  {      int a=2,b=3;      int *ptr1,*ptr2;      ptr1=&a;      ptr2=&b;      swap(prt1,ptr2);      printf(“%d,%d”,a,b);  }   这样在swap中就把p1,p2 的内容给换了,即把a,b的值互换了。 指针可以执行 增、减运算 ,结合++运算符的法则,我们可以看到: *++s 取指针变量加1以后的内容 *s++ 取指针变量所指内容后s再加1 (*s)++ 指针变量指的内容加1 指针和数组 实际上几乎是一样的,数组名可以看成是一个常量指针,一维数组中ptr=&b[0]则下面的表示法 是等价的: a[3]等价于* (a+3) ptr[3]等价于*(ptr+3) 下面看一个用指针来自己实现atoi(字符串型->整型)函数:   指向多维数组的指针变量也是一个比较广泛的运用。例如数组a[3][4],a代表的实际是整个二维数组的首地 址,即第0行的首地址,也就是一个指针变量。而a+1就不是简单的在数值上加上1了,它代表的不是a[0] [1],而是第1行的首地址,&a[1][0]。
  • 5. 指针变量常用的用途还有把指针作为参数传递给其他函数,即 指向函数的指针 。 看下面的几行代码: void Input(ST *); void Output(ST *); void Bubble(ST *); void Find(ST *); void Failure(ST *); /*函数声明:这五个函数都是以一个指向ST型(事先定义过)结构的指针变量作为参数,无返回值。*/ void (*process[5])(ST *) ={Input,Output,Bubble,Find,Failure}; /*process被调用时提供5种功能不同的 函数共选择(指向函数的指针数组)*/ printf( "nChoose:n?" ); scanf( "%d" ,&choice); if (choice >=0&&choice<=4) (*process[ choice ])(a); /*调用相应的函数实现不同功能*;/ 总之,指针的应用是非常灵活和广泛的,不是三言两语能说完的,上面几个小例子只是个引子,实际编程中, 会逐渐发现运用指针所能带来的便利和高效率。 文件: 函数调用形式 说明 fopen("路径","打开方式") 打开文件 fclose(FILE *) 防止之后被误用 fgetc(FILE *) 从文件中读取一个字符 fputc(ch,FILE *) 把ch代表的字符写入这个文件里 fgets(FILE *) 从文件中读取一行 fputs(FILE *) 把一行写入文件中 fprintf(FILE *,"格式字符串",输出表列) 把数据写入文件 fscanf(FILE *,"格式字符串",输入表列) 从文件中读取 fwrite(地址,sizeof(),n,FILE *) 把地址中n个sizeof大的数据写入文件里 fread(地址,sizeof(),n,FILE *) 把文件中n个sizeof大的数据读到地址里 rewind(FILE *) 把文件指针拨回到文件头 fseek(FILE *,x,0/1/2) 移动文件指针。第二个参数是位移量,0代表从头移,1代表从当前位置移,2 代表从文件尾移。 feof(FILE *) 判断是否到了文件末尾 文件打开方式 说明 r 打开只能读的文件 w 建立供写入的文件,如果已存在就抹去原有数据 a 打开或建立一个把数据追加到文件尾的文件 r+ 打开用于更新数据的文件 w+ 建立用于更新数据的文件,如果已存在就抹去原有数据 a+ 打开或建立用于更新数据的文件,数据追加到文件尾 注: 以上用于文本文件的操作,如果是二进制文件就在上述字母后加“b”。 我们用文件最大的目的就是能让数据保存下来。因此在要用文件中数据的时候,就是要把数据读到一个结构 (一般保存数据多用结构,便于管理)中去,再对结构进行操作即可。例如,文件aa.data中存储的是30个学 生的成绩等信息,要遍历这些信息,对其进行成绩输出、排序、查找等工作时,我们就把这些信息先读入到一 个结构数组中,再对这个数组进行操作。如下例: #include <stdio.h>  #include <stdlib.h>  #define N 30  typedef struct student /*定义储存学生成绩信息的数组*/  {      char *name;      int chinese;      int maths;      int phy;      int total;  } ST ;  main()  {      ST a[N] ; /*存储N个学生信息的数组*/      FILE *fp ;      void (*process[3])(ST *) ={Output,Bubble,Find}; /*实现相关功能的三个函数*/      int choice,i=0; 
  • 6.     Show();      printf( " Choose: ?" );      scanf( "%d" ,&choice);      while (choice>=0&&choice<=2)      {          fp=fopen( "aa.dat" , "rb" ) ;          for (i=0; i<N ;i++)              fread(&a[i], sizeof (ST),1,fp); /*把文件中储存的信息逐个读到数组中去*/          fclose(fp);          (*process[choice]) (a ); /*前面提到的指向函数的指针,选择操作*/          printf( " " );          Show();          printf( " ?" );          scanf( "%d" ,&choice);      }  }  void Show()  {      printf( " ****Choices:**** 0.Display the data form 1.Bubble it according to th e total score 2.Search 3.Quit! " );  }  void Output( ST *a ) /*将文件中存储的信息逐个输出*/  {      int i,t=0;      printf( "Name Chinese Maths Physics Total " );      for (i=0;i<N;i++)      {          t=a[i].chinese+a[i].maths+a[i].phy;          a[i].total=t;          printf( "%4s%8d%8d%8d%8d " ,a[i].name,a[i].chinese,a[i].maths,a[i].phy,a[i]. total);      }  }  void Bubble( ST *a) /*对数组进行排序,并输出结果*/  {      int i,pass;      ST m;      for (pass=0;pass <N-1 ;pass++)          for (i=0;i <N-1 ;i++)              if (a[i].total<a[i+1].total)              {                  m=a[i]; /*结构互换*/                  a[i]=a[i+1];                  a[i+1]=m;              }      Output( a );  }  void Find (ST *a)  {      int i,t=1;      char m[20];      printf( " Enter the name you want:" );      scanf( "%s" ,m);      for (i=0;i<N;i++)      if ( !strcmp(m,a[i].name)) /*根据姓名匹配情况输出查找结果*/      {          printf( " The result is: %s, Chinese:%d, Maths:%d, Physics:%d,Total:%d " ,m, a[i].chinese,a[i].maths,a[i].phy,a[i].total);          t=0 ;      }      if ( t )          printf( " The name is not in the list! " ); 
  • 7. }  链表: 链表是C语言中另外一个难点。牵扯到结点、动态分配空间等等。用结构作为链表的结点是非常适合的,例 如: struct node  {      int data;      struct node *next;  };   其中next是指向自身所在结构类型的指针,这样就可以把一个个结点相连,构成链表。 链表结构的一大优势就是动态分配存储,不会像数组一样必须在定义时确定大小,造成不必要的浪费。用mall o c和free函数即可实现开辟和释放存储单元。其中,malloc的参数多用 sizeof运算符计算得到。 链表的基本操作有: 正、反向建立链表;输出链表;删除链表中结点;在链表中插入结点 等等,都是要熟练 掌握的,初学者通过 画图 的方式能比较形象地理解建立、插入等实现的过程。 typedef struct node  {      char data;      struct node *next;  } NODE ; /*结点*/  正向建立链表:   逆向建立: NODE *create()  {      char ch= 'a' ;      NODE *p,*h=NULL;      while (ch<= 'z' )     {          p= (NODE *)malloc( sizeof (NODE)) ;          p->data=ch;          p->next=h; /*不断地把head往前挪*/          h=p;          ch++;      }      return h;  }  
  • 8. 用递归实现链表逆序输出: void output(NODE *h)  {     if (h!=NULL)     {        output(h->next) ;        printf( "%c" ,h->data);     }  }   插入结点(已有升序的链表): NODE *insert(NODE *h, int x)  {      NODE * new ,*front,*current=h;      while (current!=NULL&&(current->data<x)) /*查找插入的位置*/      {          front=current;          current=current->next;      }      new = (NODE *)malloc( sizeof (NODE)) ;      new ->data=x;      new ->next=current;      if (current==h) /*判断是否是要插在表头*/          h= new ;      else front->next= new ;      return h;  }   删除结点: NODE * delete (NODE *h, int x)  {      NODE *q,*p=h;      while (p!=NULL&&(p->data!=x))      {          q=p;          p=p->next;      }      if (p->data==x) /*找到了要删的结点*/      {          if (p==h) /*判断是否要删表头*/              h=h->next;          else q->next=p->next;          free(p); /*释放掉已删掉的结点*/      }      return h;  }
  • 9. 上一篇 Map Reduce – the Free Lunch is not over? 下一篇 程序崩了,咋办? 类别:C语言 技术圈(2) 阅读(95) 评论(1) 推送到技术圈 返回首页       相关文 章 谭浩强C语言程序设计 网络语言对作文教学的冲击 程序员和C语言没有必然联系 C语言专题——标准库<math.h> C语言实现每一分钟打开一次文件夹 将对setjmp与longjmp的具体使用方法和适用的.. C语言编程宝典之一 读书笔记 谁能帮我解决这个问题?? C语言的起源 C语言嵌入式系统编程修炼(软件架构篇)     文 章评 论   [1楼]       tonyxiaohome 2010-06-12 13:04:06 写太好了,我推荐到我的圈子里面了,http://g.51cto.com/tonyxiaohome, 有空来坐坐,大家交个朋友。   发表评 论 昵   称:  登录  快速注册 验证码: 请点击后输入验证码 博客过2级,无需填写验证码 内   容: 5 6 提 交 Copyright By 51CTO.COM 版权所有 converted by Web2PDFConvert.com